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10 INTRODUCTION 


The WD37C65C Floppy Disk Subsystem Control- 
ler is an LSI device that provides all the needed 
functionality between the host processor and the 
floppy disk drive. This "superchip" integrates the 
following functions: formatter/controller, data 
separation, write precompensation, data rate 
selection (to a maximum of 1Mbit per second), 
and clock generation. It also provides interface 
drivers and receivers for the floppy drive. 


The WD37C65C is functionally compatible pin-for- 
pin with the WD37C65A/B. In addition the 
WD37C65C supports a power down mode for lap- 
top and portable systems. Refer to Table 16-6 for 
a descripion of functional differences between the 
WD37C65A/B and the WD37C65C. 


On the disk drive interface, the WD37C65C in- 
cludes data separation designed to address high 
performance error rates on floppy disk drives. It 
contains all the necessary logic to achieve classi- 
cal 2nd order, type 2, phase locked loop perfor- 
mance. Write precompensation is included, in ad- 
dition to the usual formatting, encoding/decoding, 
stepper motor control, and status sensing func- 
tions. All inputs are TTL compatible Schmitt Trig- 
ger line receivers, and outputs are high current, 
open drain, with 48 mA drivers which meet the 
ANSI specification. 


The host interface supports an 8 or 12 MHz, 286 
microprocessor bus without the use of wait states. 
The inputs are Schmitt Triggers. Output drive 
capability is 20 LSTTL loads, allowing direct inter- 
connection to bus structures without the use of 
buffers or transceivers. For PC, PC AT and EISA 
applications, qualification of interrupt request and 
DMA request is provided. 


Traditionally, data rate selection, drive selection, 
and stepper motor control have been output ports 
of the host processor architecture. In the 
WD37C65C, these functions are latched into 
registers addressed within the I/O mapping of the 
system. The WD37C65C has eight internal 
registers. The eight bit main status register con- 
tains status information about the WD37C65C 
and may be accessed any time. Another four 
status registers under system control also give 
various status and error information. The Control 


Register provides support logic that latches the 
two LSBs used to select the desired data rate that 
controls internal clock generation. The Operations 
Register replaces the standard latched port used 
in floppy subsystems. These registers are incor- 
porated into the WD37C65C. 


All Clock Generation: SCLK - Sampling Clock, 
WCLK-Write Clock, and MCLK - Master Clock, 
are included in the WD37C65C. XTAL oscillator 
circuits provide the necessary signals for internal 
timing when using the 44-pin PLCC. If the 40-pin 
DIP is used, the TTL level clock inputs must be 
provided. There are two oscillator inputs to the 
WD37C65C. The first at 32 MHz that handles all 
Standard data rates (1 MB/s, 500, 250, and 125 
kb/s or 16 MHz to handle 500, 250, and 125 
Kb/s). The second oscillator is at 9.6 MHz to sup- 
port the 300 kb/sec data rate used in PC AT 
designs. 


Some AT compatibles use two-speed disk drives. 
If a two-speed disk drive is used, the DRV input 
should be grounded along with the CLK2 input. 


1.1 FEATURES 
¢ IBM PC AT compatible format (single and 
double density) 


—Provides "on chip" floppy control and 
operations 


—Provides required signal qualification to 
DMA channel when in PC AT mode 


—BIOS compatible 
—Supports dual speed spindle drives 


¢ CMOS low power consumption (typically 300 
mW at 32 MHz) 


¢ Power down mode with low standby current 
(ICC = 100 nA maximum) 

¢ Address mark detection circuitry (internal to 
floppy disk controller) 
Multi-sector and multi-track transfer capability 
Direct floppy disk drive interface (no buffers 
needed) 

—48 mA sink output drivers 

—Schmitt Trigger line receivers 


Reprinted with permission of and licensed by NEC Electronics Inc. © 1985 NEC Electronics Inc. 
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Compatible with PD8080/85, PD8086, 8088, 
80286, 80386SX, 80386, and PD780 (Z80) 
microprocessors 
On chip clock generation 
¢ Two TTL clock inputs for 40-pin DIP 
¢ Two XTAL oscillator circuits for 44-pin PLCC 
Automatic write precompensation 

—Disable option 

—Pin selectable inner track values of 125 or 

187 nanoseconds 

Integrated high-performance DPLL data 
separator 

—Industry standard error rates of 10<E-9 


—Data rates of 125, 250, 300, 500 
Kbits/second and 1Mbit/second 


—Option to select 150 Kbits/second FM and 
300 Kbits/second MFM data rates only 


Enhanced host interface 
—20 LSTTL output drive capability 
—TTL Schmitt trigger inputs 


¢ User programmable track stepping rate and 
head load/unload times 


Supports four floppy or Micro Floppydisk drives 
with external decode logic 


Data transfer in DMA or non-DMA mode 


Parallel seek operation on a maximum of four 
drives 


Internal power up reset circuitry 
Single +5V DC power supply 


DCHGEN [_] 17 


OnN Oa WD — 





40 PIN DIP 





44 PIN PLCC 


INTRODUCTION 
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2.0 SIGNAL DESCRIPTIONS 


D/P PIN MNEMONIC SIGNAL NAME 1/O FUNCTION 
NUMBER 
1/1 RD READ | Control signal for transfer of data or status onto the 
data bus by the WD37C65C. 
2/2 WR WRITE | Control signal for latching data from the bus into the 
WD37C65C Buffer Register. 
3/3 cs CHIP SELECT | Selected when 0 (low) allowing RD or WR operation 


from the host. 


4/4 AO ADDRESS LINE | Address line selecting data (=1) or status (=0) infor- 
mation. (AO = logic 0 during WR is illegal except in 
Power Down mode.) 


5/5 DACK DMA | Used by the DMA controller to transfer data from 
ACKNOWLEDGE the WD37C65C onto the bus. Logical equivalent to 
CS and A0=1. In Special or AT/EISA mode, this sig- 
nal is qualified by DMAEN from the Operations 


Register. 
6/6 TC TERMINAL- | This signal indicates to WD37C65C that data trans- 
COUNT fer is complete. If DMA operational mode is selected 


for command execution, TC will be qualified by 
DACK, but not in the programmed I/O execution. In 
AT/EISA or Special mode, qualification by DACK re- 
quires the Operations Register signal DMAEN to be 
logically true. Note also that in AT/EISA mode, TC 
will be qualified by DACK, whether in DMA or non- 
DMA host operation. Programmed I/O in AT/EISA 
mode will cause an abnormal termination error at 
the completion of a command. 





7-14/ DBO thru DATA BUS 0 thru VO 8-Bit, bi-directional, tristate, data bus. DO is the 
7-14 DB7 DATA BUS 7 least significant bit (LSB). D7 is the most significant 
bit (MSB). 
15/15 DMA DIRECT O DMArequest for byte transfers of data. In Special or 
MEMORY AT/EISA mode, this pin is tristated, enabled by the 
ACCESS DMAEN signal from the Operations Register. This 





pin is driven in the Base mode. 


16/16 IRQ INTERRUPT O_ Interrupt request indicating the completion of com- 
mand execution or data transfer requests (in non- 
DMA mode). Normally driven in base mode. In Spe- 
cial or AT/EISA mode, this pin Is tristated, enabled 
by the DMAEN signal from the Operations Register. 


TABLE 2-1. SIGNAL DESCRIPTION 
*Only in the PLCC version of the WD37C65C. Not connected in the DIP package. 
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WD37C65C SIGNAL DESCRIPTIONS 
D/P PIN MNEMONIC SIGNAL NAME FUNCTION 
NUMBER 
/17 DCHGEN* DISK CHANGE This input must be at Logic = 0 to enable DCHG 
ENABLE input status at pin 40 to be placed on bit 7 of the 
data bus during a RD = 0 of LDCR = 0. It has Inter- 
nal pull-up. 

17/18 LDOR LOAD Address decode which enables the loading of the 

OPERATIONS Operations Register. Internally gated with WR 
REGISTER creates the strobe which latches the data bus into 
the Operations Register. 

18/19 LDCR LOAD CONTROL Address decode which enables loading of the Con- 

REGISTER trol Register. Internally gated with WR creates the 
strobe which latches the two LSBs from the data 
bus into the Control Register. 

19/20 RST RESET Resets controller, placing microsequencer in idle. 
Resets device outputs. Puts device in Base mode, 
not PC AT or Special mode. 

20/21 RDD READ DISK This is the raw serial bit stream from the disk drive. 

DATA Each falling edge of the pulses represents a flux 
transition of the encoded data. 

21/ CLK2 CLOCK2 TTL level clock input used for non-standard data 

rates: is 9.6 MHz for 300 kb/s, and can only be 
selected from the Control Register. 

[22 XT2 ! XTAL2 XTAL oscillator drive output for 44-pin PLCC (See 
Figure 6). Should be left floating if TTL inputs used 
at pin 23. 

/23 XT2 XTAL2 XTAL oscillator input used for non-standard data 
rates. It may be driven with a TTL level signal. 

22/24 DRV DRIVE TYPE Drive type input indicates to the device that a 
twospeed spindle motor is used if logic is 0. In that 
case, the second clock input will never be selected 
and must be grounded. 

23/ CLK1 CLOCK1 TTL level clock input is used to generate all internal 
timings for standard data rates. Frequency must be 
16MHz + 0.1% or 32MHz + 0.1%, and may have 
40/60 or 60/40 duty cycle. 

/25 XT1 XTAL1 XTAL oscillator drive output for 44-pin PLCC (See 
Figure 6). Should be left floating if TTL inputs are 
used at pin 26. 

/26 XT 1 XTAL1 XTAL oscillator input requiring 16 MHz or 32 MHz 


crystal. This oscillator is used for all standard data 
rates, and may be driven with a TTL level signal. 


TABLE 2-1. SIGNAL DESCRIPTION (CONTINUED) 
*Only in the PLCC version of the WD37C65C. Not connected in the DIP package. 
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SIGNAL DESCRIPTIONS 
D/P PIN MNEMONIC SIGNAL NAME 
NUMBER 
24/27 PCVAL PRECOMPEN- 
SATIONVALUE 

25/28 HS HEAD SELECT 
26/29 WE WRITE ENABLE 
27/30 WD WRITE DATA 
28/31 DIRC DIRECTION 
29/32 STEP STEP PULSE 
30/33 DS1 DRIVE SELECT 1 
31/34 vss GROUND 
32/35 DS2 DRIVE SELECT 2 
33/36 MO1, DS3 MOTOR ON 1, 


DRIVE SELECT 3 


V/O 


WD37C65C 
FUNCTION 


Precompensation value select input. This pin deter- 
mines the amount of write precompensation used 
on the inner tracks of the diskette. Logic 1 = 125 ns, 
Logic 0 = 187 ns. If the defeat option Is used, 
PCVAL is unimportant and precompensation is dis- 
abled. 


High current driver (HCD) output selects the head 
(side) of the floppy disk that is being read or written. 
Logic 1 = side 0. Logic 0 = side 1. 


This HCD output becomes true, active low, just prior 
to writing on the diskette. This allows current to flow 
through the write head. 


This HCD output is WRITE DATA. Each falling edge 
of the encoded data pulse stream causes a flux tran- 
sition on the media. 


This HCD output determines the direction of the 
head stepper motor. Logic 1 = outward motion. 
Logic 0 = inward motion. 


This HCD output issues an active low pulse for 
each track to track movement of the head. 


This HCD output, when active low, is DRIVE 
SELECT 1 in AT/EISA mode. It enables the inter- 
face to this disk drive. This signal comes from the 
Operations Register. In Base, or Special mode, this 
output is #1 of the four decoded Unit Selects, as 
specified in the device command syntax. 


Ground. 


This HCD output, when active low, is DRIVE 
SELECT 2 in AT/EISA mode, enables the interface 
to this disk drive. This signal comes from the Opera- 
tions Register. in Base or the Special mode, this out- 
put is #2 of the four decoded Unit Selects as 
specified in the device command syntax. 





This HCD output, when active low, is MOTOR ON 
enable for disk drive #1, in AT/EISA mode. This sig- 
nal comes from the Operations Register. In the 
Base or Special mode, this output is #3 of the four 
decoded Unit Selects as specified in the device 
command syntax. 


TABLE 2-1. SIGNAL DESCRIPTION (CONTINUED) 


“Only in the PLCC version of the WD37C65C. Not connected in the DIP package. 
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WD37C65C SIGNAL DESCRIPTIONS 
D/P PIN MNEMONIC SIGNAL NAME I/O FUNCTION 
NUMBER 
34/37 MO2, DS4 MOTOR ON 2, 0 This HCD output, when active low, is MOTOR ON 
DRIVE SELECT 4 enable for disk drive #2, in AT/EISA mode. This sig- 

nal comes from the Operations Register. In the 
Base or Special mode, this output is #4 of the four 
decoded Unit Selects as specified in the device 
command syntax. 

35/38 HDL HEAD LOADED ~—_O._: This HCD output, when active low, causes the head 
to be loaded against the media in the selected drive. 

36/39 RWC, RPM REDUCED O This HCD output, when active low, causes a 

WRITE REDUCED WRITE CURRENT, when bit density is 
CURRENT, increased toward the inner tracks, becoming active 
REVOLUTIONS when tracks >28 are accessed. This condition is 
PER MINUTE valid for Base or Special mode, and is indicative of 
when write precompensation is necessary. In the 
AT/EISA mode, this signal will be active when 
CRO=1. 

/40 DCHG* DISK CHANGE | This Schmitt Trigger (ST) input senses status from 
the drive. Active low indicates that drive door is 
open or that the diskette has possibly changed 
since the last drive selection. It has internal pull-up. 

37/41 WP WRITE | This ST input senses status from the disk drive in- 

PROTECTED dicating active low when a diskette is WRITE 
PROTECTED. 

38/42 TROO TRACK 00 | This ST input senses status from disk drive, indicat- 
ing active low when the head is positioned over the 
outermost track, TRACK 00. 

39/43 IDX INDEX | This ST input senses status from the disk drive, in- 
dicating active low when the head is positioned over 
the beginning of a track marked by an index hole. 

40/44 VCC +5VDC -- Input power supply. 


TABLE 2-1. SIGNAL DESCRIPTION (CONTINUED) 


“Only in the PLCC version of the WD37C65C. Not connected in the DIP package. 
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3.0 ARCHITECTURE 


The WD37C65C Floppy Disk Subsystem Control- Figure 3-1 illustrates a block diagram of the 
ler is an LSI device that provides all the needed ©WD37C65C Floppy Disk Subsystem Controller. 
functionality between the host processor and the 

floppy disk drive. This "superchip" integrates: for- Figure 3-2 illustrates a typical WD37C65C sys- 
matter/controller, data separation, write precom- tem. 

pensation, data rate selection, clock generation, 

drive interface drivers and receivers. 


CONTROL MASTER ¥ Zz DATA OPERATION 
REGISTER Z STATUS REG x - REGISTER REGISTER 
et oe + — J | 


8 BIT INTERNAL DATA BUS 


ALU 


DISK 

BSE AN INTERFACE 
CONTROL 

REGISTER 


HOST 
INTERFACE 





CRYSTAL 
DIGITAL DATA DATA ENCODER CRC WRITE a Ww 
OSC X 2 SEPARATOR DECODER GENERATOR PRECOMPENSATION PCVAL 


*PLCC version of WD37C85C only 





FIGURE 3-1. WD37C65C BLOCK DIAGRAM 
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FIGURE 3-2. TYPICAL WD37C65 SYSTEM 
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HOST INTERFACE 


4.0 HOST INTERFACE 


The host interface is the Host Microprocessor 
Peripheral Bus. This bus is composed of eight 
control signals and eight data signals. In the Spe- 
cial or AT/EISA modes, IRQ and DMA request are 
tri-stated and qualified by DMA enable which is 
provided by the Operations Register. The data 
bus, DMA, and IRQ outputs are designed to hand- 
le 20 LSTTL loading. Inputs are Schmitt Trigger 
receivers and can be hooked up to a bus or back- 
plane without any additional buffering. 


During the Command or Result phases, the Main 
Status Register must be read by the processor 
before each byte of information is written into or 
read from the Data Register. After each byte of 
data is read from or written into the Data Register, 
the CPU waits for 12 us before reading the Main 
Status Register. Bits D6 and D7 in the Main 
Status Register must be in a O and 1 state, 
respectively, before each byte of the command 
word may be written into the WD37C65C. Many of 
the commands require multiple bytes. As a result, 
the Main Status Register must be read prior to 
each byte transfer to the WD37C65C. During the 
Result phase, Bits D6 and D7 in the Main Status 
Register must both be 1’s (D6=1 and D7=1) 
before reading each byte from the Data Register. 
Note that this reading of the Main Status Register 
before each byte transfer to the WD37C65C is 
required only in the Command and Result 
phases, and not during the Execution phase. Note 
also that DB6 and DB7 in the MSR can be polled 
instead of waiting 12 us. 


During the Execution phase, the Main Status 
Register need not be read. If the WD37C65C is in 
the non-DMA Mode, then the receipt of each data 
byte (WD37C65C is reading data from the FDD) 
is indicated by an interrupt signal on pin 16 
(IRQ=1). The generation of a Read signal (RD = 
0) clears the interrupt and sends the data onto the 
data bus. If the processor cannot handle inter- 
rupts fast enough (every 13 us for the MFM mode 
and 27 us for the FM mode), then it may poll the 
Main Status Register and bit D7 (RQM) functions 
as the Interrupt signal. If a Write Command is in 
process then the WR signal performs the reset to 
the Interrupt signal. 


All timings mentioned above double for mini flop- 
py data rates. 


WD37C65C 


Note that in the non-DMA mode it is necessary to 
examine the Main Status Register to determine 
the cause of the interrupt since it could be a data 
interrupt or a Command termination interrupt, 
either normal or abnormal. If the WD37C65C is in 
the DMA mode, no interrupt signals are generated 
during the Execution phase. The WD37C65C 
generates DMA’s (DMA Requests) when each 
byte of data is available. The DMA Controller 
responds to this request with both DACK=0 (DMA 
Acknowledge) and an RD=0 (Read signal). When 
the DMA Acknowledge signal goes low 
(DACK=0), the DMA Request is cleared (DMA= 0) 
lf a Write Command has been issued, then a WR 
signal will appear instead of RD. After the Execu- 
tion phase has been completed (Terminal Count 
has occurred) or the EOT sector read/written, 
then an Interrupt will occur (IRQ = 1). This sig- 
nifies the beginning of the Result phase. When 
the first byte of data is read during the Result 
phase, the interrupt is automatically cleared (IRQ 
= 0). 





Note that in PC AT usage, non-DMA Host trans- 
fers are not the normal procedure. If the user 
chooses to do so, the WD37C65C will successful- 
ly complete commands, but will always give ab- 
normal termination error status since TC is 
qualified by an inactive DACK. 





The RD or WR signals should be asserted while 
DACK is true. The CS signal is used in conjunc- 
tion with RD and WR as a gating function during 
programmed I/O operations. CS has no effect 
during DMA operations. If the non-DMA mode is 
chosen, the DACK signal should be pulled up to 
Vcc. Note that during the Result phase all bytes 
shown in the Command Table must be read. The 
Read Data Command, for example, has several 
bytes of data in the Result phase. All seven bytes 
must be read in order to successfully complete 
the Read Data command. The WD37C65C will 
not accept a new command until all seven bytes 
have been read. Other commands may require 
fewer bytes to be read during the Result phase. 
The WD37C65C contains five Status Registers. 
The Main Status Register mentioned may be read 
by the processor at any time. The other four 
Status Registers (STO, ST1, ST2, and ST3) are 
available only during the Result phase and may 
be read only afler completing a command. The 
particular command that has been executed 
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HOST INTERFACE 





determines how many of the Status Registers will 
be read. 


The bytes of data which are sent to the 
WD37C65C to form the Command phase, and are 
read out of the WD37C65C in the Result phase, 
must occur in the order shown in the Command 
Table. The command code must be sent first and 
the other bytes sent in the prescribed sequence. 


No foreshortening of the Command or Result 
phases is allowed. After the last byte of data in the 
Command phase is sent to the WD37C65C, the 
Execution phase automatically starts. In a similar 
fashion, when the last byte of data is read out in 
the Result phase, the command is automatically 
ended and the WD37C65C is ready for a new 
command. 
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5.0 CONTROL REGISTER 


The Control Register is a write only register that is 
used to set the data transfer rate and disable write 
precompensation. It provides support logic that 
latches the two LSBs of the data bus upon receiv- 
ing LDCR and WR. CS should not be active when 
this happens. These bits are used to select the 
desired data rate, which in turn controls the inter- 
nal clock generation. Clock switchover is internal- 
ly "deglitched," allowing continuous operation 
after changing data rates. If the Control Register 
is not used, the data rate is governed by the sup- 
plied clock or crystal. The frequency must be 64 
times the desired MFM data rate. This implies a 
maximum data rate of 250 kb/s for a frequency of 
16 MHz or a maximum data rate of 500 Kb/s fora 
frequency of 32 MHz, unless the Control Register 











CR1 CRO DRV DATA RATE COMMENTS 
o  |o |x _—*|500K 

0 0 

0 { 0 ——=«di 2K MFM 

0 { MFM, (9.6 MHz XTAL) 
250 K MEM, RST Default 
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is used. Switching of this clock must be "glitch- 
less" or the device will need to be reset. Table 5-1 
and Table 5-2 present the Control Register con- 
figuration for 16 MHz and 32 MHz frequencies, 
respectively. 


The WD37C65C optionally supports 150 kb/s FM 
data transfer rate. The Control Register configura- 
tion is shown in Table 5-3. The 150 kb/s data rate 
can be selected by using a 9.6 MHz XTAL or TTL 
level clock input on pin 26 (44-pin PLCC) or pin 
23 (40-pin DIP). Only two data transfer rates can 
be selected with this configuration: 150 kb/s FM 
and 300 kb/s MFM. 














FM, RST Default 1 


TABLE 5-1. CONTROL REGISTER CONFIGURATION - 16 MHZ 






Ce aT 
o ix =| 600 k 


500 K 


as (ee 








Oo |x «| 500 K MFM, RST Default | 4 

















COMMENTS RPM 
AT/EISAMODE 

MFM { 

FM { 

MFM 0 

MFM,(9.6 MHz XTAL)|0 











TABLE 5-2. CONTROL REGISTER CONFIGURATION - 32 MHz 
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In AT/EISA mode, write precompensation can be 
disabled by a logic high on bit 2 of the Control 
Register. (See Table 5-4). 














CRi (CRO. |DRV _ |DATARATE COMMENTS RPM 
AT/EISA MODE 
Meee 


00 K MFM sd 
150 K 


SIGNAL NAME AND RESET CONDITION CLOCK QUALIFIER 
FUNCTION 


Data Rate 


oF 
Data Rate o  — IN 
No Write Precompensation IO. Od 





TABLE 5-4. CONTROL REGISTER CONFIGURATION - AT/EISA MODE 
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6.0 MASTER STATUS REGISTER 


The Master Status Register is an eight-bit, 
read/write register that contains the status infor- 
mation of the FDC. It can be accessed at any 
time. The WD35C65C provides a write only 
register, called Master Status Register 1 (MSR1) 
which is used only to select power down mode. In 
power down mode the XTAL oscillator, controller 
circuitry and all linear circuitry are turned off so 
that the controller draws very low current. Normal 
operation is restored by asserting reset to the 
WD37C65C. See Master Status Register 1. 


Only the Master Status Register may be read and 
used to facilitate the transfer of data between the 
processor and WD37C65C. The DIO and RQM 
bits in the Master Status Register indicate when 
data is ready and in which direction data will be 
transferred on the data_bus. The maximum time 
between the last RD or WR during a Command or 
Result phase and the setting of DIO and RQM is 
12 us if 500 kb/s MFM data rate is selected. (If 
250 kb/s MFM is selected, the delay is 24 us. If 1 
Mb/s is selected, the delay is 6 us.) For this 
reason, everytime the Master Status Register is 
read, the CPU should wait 12 us. The maximum 
time from the trailing edge of the last RD in the 
result phase to when DB4 (FDC busy) goes low is 
12 us. 


The bits in the Master Status Register are listed in 
Table 6-1. The bits in Status Register 0 are listed 






SIGNAL NAME & RESET CONDITION CLOCK QUALIFIER 
FUNCTION 


Powerdownmode(PDM) j0 Nome 


in Table 6-2.The bits in Status Register 1 are 
listed in Table 6-3.The bits in Status Register 2 
are listed in Table 6-4.The bits in Status Register 
3 are listed in Table 6-5. 


6.1 MASTER STATUS REGISTER 1 
(MSR1--WRITE ONLY) 


The WD37C65C will enter power down mode, 
when bit 0 of MSR1 is set to logical "1" and the 
following conditions are met: 


1. The RST pin to the FDC is inactive. 
2. Bit 2 in the Operations Register is "SRST/= 1". 


3. The WD37C65C is awaiting a command from 
the host. 


The WD37C65C can also be programmed with 
external logic to automatically enter power down 
mode a few milliseconds after the beginning of 
idle mode. 


Normal operation is restored when the RST pin to 
the FDC is active and the FDC is reset. This in 
turn resets bit O of MSR1 register to logic 0. 

The bits in the Master Status Register are listed in 
Table 6-2. 






None 





TABLE 6-1. AT/EISA MODE. MASTER STATUS REGISTER 1 CONFIG. 
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BIT 
NAME SYMBOL DESCRIPTION 


FDD 0 BUSY DOB FDD number is 0 in the Seek Mode. If any of the 
bits is set, FDC will not accept READ or WRITE 
commands. 


FDD 1 BUSY FDD number 1 is in the Seek Mode. If any of the 
bits is set, FDC will not accept READ or WRITE 
commands. 


FDD 2 BUSY FDD number 2 is in the Seek Mode. If any of the 
bits is set, FDC will not accept READ or WRITE 
commands. 


FDD 3 BUSY FDD number 3 is in the Seek Mode. If any of the 
bits is set, FDC will not accept READ or WRITE 
commands. 


FDC BUSY A READ or WRITE command is in progress. FDC 
will not accept any other command. 


EXECUTION This bit is set only during Execution phase in non- 
MODE DMA mode. When DB5 goes low Execution phase 
_ has ended and Results Phase has started. It 


operates only during non-DMA mode of operation. 


DATA INPUT Indicates direction of data transfer between FDC 
and Data Register. If DlIO=1, then transfer is from 
Data Register to the processor. If DlIO=0, then trans- 
fer is from the processor to Data Register. 


REQUEST FOR Indicates Data Register is ready to send or receive 

MASTER data to or from the processor. Both bits DIO and 
RQM should be used to perform the handshaking 
functions of "ready" and "direction" to the processor. 





TABLE 6-2. STATUS REGISTER 0 BITS 
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xX 


BIT 
NAME SYMBOL 


INTERRUPT IC 
CODE 


SEEK END 


EQUIPMENT 


CHECK 


NOT READY 


HEAD SELECT 


UNIT SELECT 1 


UNIT SELECT 0 
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DESCRIPTION 


D7=0 and D6=0. Normal termination of command 
was completed and properly executed. D7=0 and 
D6=1. Abnormal termination of command, (AT). Ex- 
ecution of command was started but was not suc- 
cessfully completed. 


D7=1 and D6=0. Invalid command issue, (IC). Com- 
mand which was issued was never started. 


When the FDC completes the SEEK command, this 
flag is set to 1 (high). 


If the Track 0 signal fails to occur after 77 step pul- 
ses per Recalibrate Command, then this flag is set. 


Since drive Ready is always presumed true, this will 
always be a logic 0. 


This flag is used to indicate the state of the head at 
interrupt. 


This flag is used to indicate a Drive Unit Number at 
interrupt. 


This flag is used to indicate a Drive Unit Number at 
interrupt. 


TABLE 6-3. STATUS REGISTER 1 BITS 
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SYMBOL DESCRIPTION 


END OF When the FDC tries to access a sector beyond the 
CYLINDER final sector of a cylinder, this flag is set. 


= Not used. This bit is always 0 (low). 


DATA ERROR When the FDC detects a *CRC error in either the ID 
field or the data field, this flag is set. 


OVERRUN If the FDC is not serviced by the host system during 
data transfers within a certain time interval, this flag 
is set. 


ae Not used. This bit is always 0 (low). 


NO DATA During execution of READ DATA, WRITE 
DELETED DATA, or SCAN command, if the FDC 
cannot find the sector specified in the **IDR 
Register, this flag is set. 


During execution of the READ ID command, if the 
FDC cannot read the ID field without an error, then 
this flag is set. 


During execution of the READ A TRACK command, 
if the starting sector cannot be found, then this flag 
is set. 


NOT WRITEABLE During execution of WRITE DATA, WRITE 
DELETED DATA or FORMAT A TRACK commands, 
if the FDC detects a WP signal from the FDD, then 
this flag is set. 


MISSING lf the FDC cannot detect the ID Address Mark after 
ADDRESS MARK encountering the index hole twice, then this flag is 
set. 


If the FDC cannot detect the Data Address Mark or 
Deleted Data Address Mark, this flag is set. At the 
same time the MD (Missing Address Mark in data 
field) of Status Register 2 is set. 





TABLE 6-4. STATUS REGISTER 2 BITS 
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SYMBOL 


CONTROL MARK 


DATA ERROR 


WRONG 
CYLINDER 


SCAN EQUAL 


SCAN NOT 


BAD CYLINDER 


MISSING 
ADDRESS MARK 
IN DATA FIELD 
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DESCRIPTION 


Not Used. This bit is always 0 (low). 


During execution of the READ DATA or SCAN Com- 
mand, if the FDC encounters a sector which con- 
tains a Deleted Data Address Mark, this flag is set. 


If the FDC detects a CRC error in the data field, 
then this flag is set. 


This bit is related to the ND bit, and when the con- 
tents of ** *C on the medium is different from that 
stored in the IDR, this flag is set. 


During execution of the SCAN command, if the con- 
dition of "equal" is satisfied, this flag is set. 


During execution of the SCAN command, if the 
FDC cannot find a sector on the cylinder which 
meets the condition, then this flag is set. 


This bit is related to the ND bit, and when the con- 
tents of C on the medium is different from that 
stored in the IDR and the contents of C is FF, then 
this flag is set. 


When data is read from the medium, if the FDC can- 
not find a Data Address Mark or Deleted Data Ad- 
dress Mark, then this flag is set. 


TABLE 6-5. STATUS REGISTER 3 BITS 
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BIT 
NAME SYMBOL 


WRITE 
PROTECTED 


READY 
TRACK 0 


WRITE 
PROTECTED 


HEAD SELECT 


UNIT SELECT 1 


UNIT SELECT 2 


MASTER STATUS REGISTER 


DESCRIPTION 
Not used. Will always be logic 0. 


This bit is used to indicate the status of the WRITE 
PROTECTED signal from the FDD. 


This bit will always be a logic 1. Drive is presumed 
to be ready. 


This bit is used to indicate the status of the Track 0 
signal from the FDD. 


This bit is used by the WD37C65C to indicate the 
status of the WRITE PROTECTED signal from the 
FDD. 


This bit is used to indicate the status of the Side 
Select signal to the FDD. 


This bit is used to indicate the status of the Unit 
Select 1 signal to the FDD. 


This bit is used to indicate the status of the Unit 
Select 0 signal to the FDD. 





TABLE 6-6. MASTER STATUS REGISTER BITS 


* CRC - Cyclic Redundancy Check ***C - Cylinder 


** IDR - Internal Data Register t - Different from NEC765 
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7.0 DATA REGISTER 


The eight-bit Data Register stores data, com- ‘The relationship between the Master Status 
mands, parameters, and FDD status information. Register and the Data Register and the signals 
Data bytes are read out of, or written into, the RD, WR, and AO are shown in Table 7-1. 

Data Register in order to program or obtain the 

results after a particular command. 








AO IRD WRUCSFUNCTION, 
oo Read Main Status Register 
i MO re te ee 
oo fo leg! 
a Se | ees | ere 
foo Read from Data Register 
fot Write into Data Register 





TABLE 7-1. MASTER STATUS AND DATA REGISTERS RELATIONSHIPS 
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8.0 OPERATIONS REGISTER 


The Operations Register provides support_logic — to control disk drive spindle motors and to select 
that latches the data bus upon receiving LDOR _ the desired disk drive. Table 8-1 represents the 
and WR. CS should not be active when this hap- § Operations Register. 

pens. The Operations Register replaces the typi- 

cal latched port found in floppy subsystems used 






NO. _|SYMBOL [DESCRIPTION 
ae DSEL Drive Select, if low and MOEN1 = 1, then DS1 is active. If high and MOEN2 = 






1, then DS2 is active, but only in the AT/EISA mode. 


This must be a logic O for DS1 and DS2 to become active 
SRST 


OR ive. 
| 

outputs and DACK input. 
OR7 i 


Has no defined function. A spare 


for (MSEL) Mode Select. During a soft reset condition, may be used to select between 
Special mode (1) and AT/EISA mode (0). 


TABLE 8-1. OPERATIONS REGISTER 
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9.0 BASE, SPECIAL, AND AT/EISA MODES 


Base, Special, PC AT and EISA modes allow sub- 
tle differences which the user may find desirable. 
The Control Register may be used in any mode 
without altering functionality. 


9.1 BASE MODE 


After a hardware reset, RST active, the 
WD37C65C will be held in soft reset, SRST ac- 
tive, with the normally driven signals, DMA re- 
quest and IRQ request outputs tristated. Base 
mode may be initiated at this time by a chip ac- 
cess by the host. Although this may be any read 
or write, it is strongly recommended that the Base 
mode user's first chip access be a read of the 
Master Status Register. Once Base mode is 
entered, the soft reset is released, and IRQ and 
DMA are driven. Base mode prohibits the use of 
the Operations Register, hence there can be no 
qualifying by DMAEN_and no_soft resets. The 
Drive Select outputs, DS1 to DS4, offer a 1 of 4 
decoding of the Unit Select bits resident in the 
command structure. Pin RWC represents Reduce 
Write Current and is indicative of when write 
precompensation is necessary. 





9.2 SPECIAL MODE 


Special mode allows use of the Operations 
Register for the DMAEN signal as a qualifier and 
to do a software driven device reset, SRST. To 
enter Special mode, the Operations Register is 
loaded with (1 X 0 0 X O X X), setting mode Select 
to a logic_1 disabling MOEN1 and MOEN2 and 
causing SRST to be active. Then a read of the 
Control Register address, LDCR and_RD, places 
the device in Special mode. The DS1_ through 
DS4 is again offered in this mode, as is RWC. 








9.3. AT/EISA MODES 


For AT/EISA compatibility, users write to the 
Operations Register, LDOR and WR; this action, 


performed after a hardware reset, or in the Base 
mode, initiates AT/EISA mode. AT/EISA mode can 
also be entered from Special mode by loading the 
Operations Register with (0 X 0 0 XO X X), setting 
Mode Select to a logic_0, disabling MOEN1 and 
MOEN2, and causing SRST to be active. Then a 
read of the Control Register address sets the 
device into AT/EISA mode. The DS outputs are 
replaced with the DSEL and MOEN signals buf- 
fered from the Operations Register. DMAEN and 
SRST are supported and compatible with the cur- 
rent BIOS. RWC pin function is now RPM so that 
users with two-speed drives may reduce spindle 
speed from a nominal 360 revolutions per minute 
to 300 revolutions per minute when active low. It 
can also be used to reduce write current when a 
slower data rate is selected for a given drive. Fig- 
ure 9-1 illustrates the relationship among the 
three modes. 


Hardware 
Reset 


— 


Write "80" 
to Oper Reg 


Read Master 
Status Reg 


Read Cont Reg 
LDCR, RD 


Write "00" 
Write to Oper. Reg. 
to Oper Reg 

















Read Cont. Reg 
AT/EISA LDCR, RD 
Mode 











FIGURE 9-1. FLOW DIAGRAM BASE, SPECIAL 
& AT/EISA MODES 
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10.0 POLLING ROUTINE 


After_any reset the WD37C65C, (a hard RST or 
soft SRST), will automatically go into a. Polling 
routine. In between commands (and between step 
pulses in the SEEK Command), the WD37C65C 
polls all four FDDs looking for a change in the 
Ready line from any of the drives. Since the drive 
is always presumed Ready, an interrupt will only 
be generated following a reset. This occurs be- 
cause a reset forces Not Ready status, which 
then promptly becomes Ready. Note that in Spe- 
cial, AT/EISA modes, if DMAEN is not valid 1 ms 
after reset goes inactive, then IRQ may be al- 


POLLING ROUTINE 


ready set and pending when finally enabled onto 
the bus. The polling of the Ready line by the 
WD37C65C occurs continuously between com- 
mands. Each drive is polled every 1.024 ms, ex- 
cept during the READ/WRITE commands. For 
mini-floppies, the polling rate is 2.048 ms. The 
drive polling sequence is 1-2-4-3. Note that in the 
AT/EISA mode, the user will not see the polling at 
the Drive Select signals. Figure 10-1 illustrates 
the Drive Select Polling Timing. 





FIGURE 10-1. DRIVE SELECT POLLING TIMING 
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11.0 DEVICE RESETS 


The WD37C65C supports both hardware_reset 
(RST) pin (19) and a software reset (SRST) 
through use of the Operations Register. The RST 
pin will cause a device reset for the active dura- 
tion. RST causes a default to Base mode, and 
selects 250 Ko MFM (or 125 Kb FM, code de- 
pendent) as the data rate (16 MHz input clock). 
The default data_rate for a 32 MHz input clock is 
500 Kb MFM. SRST will reset the microcontroller 
as did the RST, but will not affect the current data 
rate selection or the mode. RST, when active, will 
disable the high current driver outputs to the disk 





WD37C65C 


drive. RST and SRST will not affect the values set 
for the internal timers - HUT, HTL, and SRT. 


lf the XTAL oscillators are used, instead of the 
TTL driven clock inputs, the hardware RST active 
time requirement will be extended. The oscillator 
circuit is designed so that RST will bootstrap the 
circuit into guaranteed oscillation in a fixed 
amount of time. The extended reset time allows 
the growth of the oscillation to produce stable in- 
ternal clock timing. 
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12.0 DATA SEPARATOR 


The Data Separator is a WD92C32 Digital Phase 
Lock Loop Floppy Disk Data Separator (DPLL). It 
was designed to address high performance error 
rates on floppy disk drives, and to provide supe- 
rior performance in terms of available bit jitter 
tolerance. It contains the necessary logic to 
achieve classical 2nd order, type 2, phase locked 


DATA SEPARATOR 


loop performance. Figure 3-1 illustrates the 
WD92C32 used as the Data Separator in the 
WD37C65C system. Figure 13-1 illustrates the 
WD92C32 simplified block diagram. The bit jitter 
tolerance for the data separator is 60%, which 
guarantees an error rate of <10E-9. 
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13.0 WRITE PRECOMPENSATION 


The WD37C65C maintains the standard first level 
algorithm to determine when write precompensa- 
tion should be applied. The EARLY and LATE sig- 
nals are used internally to select the appropriate 
delay in the write data pulse stream. The encoded 
WRITE DATA signal is synchronized to the 16 
MHz or 32 MHz clock if this is the frequency on 
CLK1 pin (23), and clocked through a shift 
register. Signals EARLY, NOM, and LATE deter- 
mine the amount of delay through the shift 
register before a multiplexer gates the chosen bit 
to the output. The output data pulse width has a 
25% duty cycle, i.e., one fourth of the bit cell 
period, and equal to one half the WCLK period. 


When PCVAL pin (24) = 1, all data will be precom- 
pensated by + 125 ns, regardless of track number 
and data rate. However, this is only for MFM en- 
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coding. There is no write precompensation for 
FM. lf PCVAL = 0, and if a track inside number 28 
is accessed, then + 187 ns precompensation will 
be generated. For frequencies other than 16 MHz 
or 32 MHz on the CLK1 pin, the precompensation 
values will be two and three clock cycles respec- 
tively. 


When the non-standard 300 Kb/s data rate using 
CLK2 is chosen, the MFM precompensation will 
always be two clock cycles. For 9.6 MHz, this is + 
208 ns. In this case, the PCVAL function is dis- 
abled. 


Write precompensation can be disabled by bit 2 of 
the Control Register for the AT/EISA. The PCVAL 
input to WD37C65C is ignored if there is no write 
precompensation. 


RDATA 
RE SYNCHRONIZATION 


SUMMER 


DIGITAL 
CONTROLLED 
OSCILLATOR 


FIGURE 13-1. WD92C32 SIMPLIFIED BLOCK DIAGRAM 
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14.0 CLOCK GENERATION 


This logical block provides all the clocks needed 
by the WD37C65C. They are: Sampling Clock 
(SCLK), Write Clock (WCLK), and the Master 
Clock (MCLK). 


SCLK drives the WD92C32 Data Separator used 
during data recovery. This clock’s frequency is al- 
ways 32 times the selected data rate. 


WCLK is used by the encoder logic to place MFM 
or FM on the serial WD-stream to the disk. WCLK 
always has a frequency two times the selected 
data rate. 


MCLK is used by the microsequencer. MCLK and 
MCLK clock all latches in a two-phase scheme. 
One microinstruction cycle is four MCLK cycles. 
MCLK has a frequency equal to eight times the 
selected MFM data rate or 16 times the FM data 
rate. Table 14-1 presents the Clock Data Rate. 


Figure 14-1 illustrates the XTAL oscillator circuits 
for the 44-pin PLCC configuration. 


In power down mode the XTAL oscillator and the 














ik 









MFM (32.0 | Q. 
= kb/s |MFM  |16.0 _|4.0 
250 kb/s (MEM [8.0 [2.0 [500 KHz 
1254s FM (4 0.___|20__280KHe 
6 (24 (600 KHz 





clock circuitry are turned off. 
DATA |CODE (|SCLK |MCLK /|WCLK 
sas ra ae 

3.0 ‘2. 0 MHz 

00 kb/s |FM 

250kb/s|FM |8.0 {4.0 500 KHz 
300 kb/s 
TABLE 14-1. CLOCK DATA RATE 





SERIES RESONANT 
2 


9.6 MHz 
R series 
C shunt 
C1 
C2 


100 ppm 

30 ohm max 
10 pf max 

68 pf 5% mica 
56 pf 5% mica 


tot wo oui we 


SERIES RESONANT 
XT1 


16.0 MHz 32 MHz 
R series 30 ohm max R series 
C shunt 10 pf max C shunt 
C3 47 pf 5% mica C3 


C4 15 pf 5% mica C4 


100 ppm ppm 

47.2 ohm 

2 pf max 

30 pf 5% mica 


30 pf 5% mica 


toi a 





FIGURE 14-1. CRYSTAL OSCILLATOR CIRCUITS FOR 44-PIN PLCC 
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15.0 COMMAND PARAMETERS 


The WD37C65C is capable of performing 15 dif- 
ferent commands. Each command is initiated by a 
multibyte transfer from the processor. The results 
after execution of the command may also be a 
multibyte transfer back to the processor. The com- 
mands consist of three phases: Command phase, 
Execution phase, and the Result phase. 


Command phase - The Floppy Disk 
Controller (FDC) receives all information 
required to perform a particular operation from 
the processor 


Execution phase - The FDC performs the 
operation it was instructed to do. 

Result phase - After completion of the 
operation, status and other housekeeping 
information are made available to the 
processor. 


Table 15-1 lists the 15 WD37C65C commands. 








EXECUTION 


RESULTS 





WD37C65C 


READ DATA 

READ DELETED DATA 
WRITE DATA 

WRITE DELETED DATA 
READ A TRACK 

READ ID 

FORMAT A TRACK 


SCAN EQUAL 

SCAN LOW OR EQUAL 
SCAN HIGH OR EQUAL 
RECALIBRATE 

SENSE INTERRUPT STATUS 
SPECIFY 

SENSE DRIVE STATUS 
SEEK 


TABLE 15-1. WD37C65C COMMANDS 





Tables 15-1 through 15-16 are presented to show 
the required parameters and results for each com- 
mand. Most commands require nine command 
bytes and return seven bytes during the result 
phase. The "W" to the left of each byte indicates a 
command phase byte to be written. An "R" indi- 
cates a result byte. 


REMARKS 


Command Codes 





Sector ID information prior to 
command execution. The four 
bytes are compared against 
header on floppy disk. 


mand execution. 


Sector ID information after com- 
mand execution. 





TABLE 15-2. READ DATA 
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Sector ID information prior to 
command execution. The four 
bytes are compared against 
header on floppy disk. 


Data transfer between FDD and 
main system. 


Sector ID information after com- 
mand execution. 





TABLE 15-3. READ DELETED DATA 


Sector ID information prior to 
command execution. The four 
bytes are compared against 
header on floppy disk. 


Data transfer between FDD and 
main system. 


RESULTS 


Sector ID information after com- 
mand execution. 





TABLE 15-4. WRITE DATA 
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Command Codes 


Sector ID information prior to 
command execution. The four 
bytes are compared against 
header on floppy disk. 


Data transfer between FDD and 
main system. 


EXECUTION 


RESULTS 





Sector ID information after com- 
mand execution. 











sinebaiias UA iniecbinince 


TABLE 15-5. WRITE DELETED DATA 


TP ccuneee. 


REMARKS 
Command Codes 


Sector ID information prior to 
command execution. 














DIL |DTL |DTL |DTL 


Data transfer between FDD and 
main system. FDD reads all data 


fields from index hole to EOT. 








EXECUTION 


RESULTS l 
Sector ID information after com- 
mand execution 


TABLE 15-6. READ A TRACK 
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Raw {oy {Dé (Ds {ps {os (oa {o1 |po_ REMARKS 


ee | i Command Codes 
ie ic We 
iol The first correct ID information on 
the cylinder is stored in Data 


RESULTS 


Sector ID information read during 
Execution Phase from floppy 
disk. 





TABLE 15-7. READ ID 











De js (DS (84 8 108 it (pe REMARKS 


PHASE 0 0 | Command Codes 
X * : Hs ust 
N 
SC 56 i ws ae ie Ma 
GPL ae ie ie is ile Si 
D 


a 


RESULTS 


: i] 
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=2=z=z=== 






Floppy Disk Controller (FDC) for- 
mats an entire track. 






In this case, the ID information 


R 
R 
R 
R 
R 
R has no meaning. 
R 





TABLE 15-8. FORMAT A TRACK 
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EASE. Et IOS Be IDSs Oe. IIe REMARKS 


Command Codes 


Sector ID information prior to 
command execution. 


=zzzZzZzZz=z= 


Data compared between FDD 
and main system. 


RESULTS 


Sector ID information after com- 
mand execution. 


Sector ID information prior to 
command execution. 





Data compared between FDD 
and main system. 





RESULTS 


Sector ID information after com- 
mand execution 





TABLE 15-10. SCAN LOW OR EQUAL 





| | 
ff 11/18/91 26-31 


WD37C65C COMMAND PARAMETERS 


PHASE ____ AW 07 (Dé (Ds [na {py [02 fot {p9__ REMARKS 


Command Codes 


Sector ID information prior to 
command execution. 


a cca 


Data compared between FDD 
and main system. 


Sector ID information after com- 
mand execution. 


RW |D7_|p6 [D5 |p4 |D3 |D2 (D1 |DO |REMARKS 


COMMAND |W { Command Codes 
Ww 0 |US1/USO 


EXECUTION | | | | | | | [Head retracted to Track zero. 


TABLE 15-12. RECALIBRATE 


The WD37C65C issues 77 step pulses, the same 
as the NEC765. 













PHASE ———{RML.B? D6. .08_{p4_{03_.p2_ {01 _Do_ REMARKS 

COMMAND 9 70 jo _to__ 10 |Command Codes 

RESULTS STO een o STO |Status information about the FDC 
N|PCN|IPCN|PCN|PCN|PCN|PCN |at the end of seek operation 


TABLE 15-13. SENSE INTERRUPT STATUS 
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PHASE _|R/W a BE_{B6 IGS. (BS_ 18. fee, (Ot De REMARKS 


COMMAND . 0 0 0 0 1 1 Command Codes 
— aap SRT |SRT | HUT] HUT | HUT | HUT 
HLT |HLT |HLT |HLT |HLT }HLT |HLT |ND 


TABLE 15-14. SPECIFY 
























PHASE _—[R/WD7_|D6 |D5 [D4 |D3 |D2 |D1 |DO_|REMARKS 
COMMAND Command Codes 
W |X |X |X |X {|X HS |US1|USO 
on ee ST3 se ie Wid aid es ibd information about the 
FDC. 


TABLE 15-15.SENSE DRIVE STATUS 


Oo 



















[DO |REMARKS 
Command Codes 


PHASE ____{RW {D7 _[D6_{0s_{p4_{n_{o2__ 


COMMAND 
18 us USO 
NEN NCN NCN NCN NCN NCN |NCN |NCN 
— eee 


TABLE 15-16. SEEK 









Head is positioned over 
proper cylinder on the 
diskette. 
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Table 15-17 defines, in alphabetical order, the symbols used in Command Tables 15-1 through 15-16. 


SYMBOL NAME DESCRIPTION 


AO ADDRESS LINE 0 AO controls selection of Main Status Register (AO=0) or Data Register 
(AO=1). 
C CYLINDERNUMBER ~ Cstands for the current/selected cylinder (track) numbers 0 through 255 
of the medium. 
D DATA D stands for the data pattern which is going to be written into a sector. 
D7 - DO DATA BUS 8-bit DATA BUS, where D7 stands for a most significant bit, and DO 
stands for a least significant bit. 

DTL DATA LENGTH When N is defined as 00, DTL stands for the DATA LENGTH which users 
are going to read out or write into the sector. 

EOT END OF TRACK EOT stands for the final sector number on a cylinder. During Read or 
Write operations, FDC will stop data transfer after a sector number equal 
to EOT. 

GPL GAP LENGTH GPL stands for the length of Gap 3. During the FORMAT Command, it 
determines the size of Gap 3. 

H HEAD ADDRESS H stands for head number 0 or 1 as specified in the ID field. 

HLT HEAD LOAD TIME HLT stands for the HEAD LOAD TIME in FDD (2 to 254 ms in 2 ms incre- 
ments). 

HS HEAD SELECT HS stands for a selected head number 0 or 1 and controls the polarity of 


pin 25 (in 40-pin DIP) or pin 28 (in 44-pin PLCC). 


HUT HEAD UNLOAD TIME HUT stands for the HEAD UNLOAD TIME after a Read or Write operation 
has occurred (16 to 240 ms tn 16 ms increments). 


MF FM or MFM If MF is low, FM mode is selected. If it is high, MFM mode is selected. 


MT MULTITRACK If MT is high, a MULITRACK operation is performed. If MT=1 after finish- 
ing Read/Write operation on side 0, FDC will automatically start searching 
for sector 1 on side 1. 


N NUMBER N stands for the NUMBER of data bytes written in a sector. 
NCN NEW CYLINDER NCN stands fora NEW CYLINDER NUMBER which is going to be 
NUMBER reached as a result of the Seek operation. Desired position of head. 
ND NON-DMA MODE ND stands for operation in the NON-DMA MODE. 


PCN PRESENT CYLINDER PCN stands for the cylinder number at the completion of the SENSE IN- 
TERRUPT STATUS Command. Position of head at present time. 


TABLE 15-17. COMMAND SYMBOL DESCRIPTIONS 
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SYMBOL NAME 
RECORD 


READ/WRITE 
SECTOR 
SK SKIP 


SRT STEP RATE TIME 


STATUS 0 
STATUS 1 
STATUS 2 
STATUS 3 


USO,US1 UNIT SELECT 





. 


DESCRIPTION 


R stands for the sector number which will be read or written. 
R/W stands for either READ or WRITE signal. 

SC indicates the number of sectors per cylinder. 

SK stands for SKIP Deleted Data Address mark. 


SRT stands for the Stepping Rate for the FDD (1 to 16 ms in 1 ms incre- 
ments). Stepping Rate applies to all drives. In 2’s complement format, 
F(Hex)=1 ms, E(Hex)=2 ms, etc. 


STO0-3 stands for one of four registers which store the STATUS informa- 
tion after a command has been executed. This information is available 
during the result phase after command execution. These registers should 
not be confused with the Main Status Register (selected by AO=0). STO-3 
may be read only after a command has been executed and contains infor- 
mation relevant to that particular command. 


During a SCAN operation, if STP=1, the data in contiguous sectors is com- 
pared byte by byte with data sent from the processor (or DMA); if STP=2, 
then alternate sectors are read and compared. 


US stands for a selected drive; binary encoded, 1 of 4. 


TABLE 15-17. COMMAND SYMBOL DESCRIPTIONS (CONTINUED) 
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16.0 COMMAND DESCRIPTIONS 
16.1 READ DATA 


A set of nine byte words are required to place the 
FDC into the Read Data Mode. After the Read 
Data command has been issued, the FDC loads 
the head (if it is in the unloaded state), waits the 
specified head settling time (defined in the Specify 
Command), and begins reading ID Address Marks 
and ID fields. When the current sector number (R) 
stored in the ID Register (IDR) compares with the 
sector number read off the diskette, then the FDC 
outputs data (from the data field) byte-to-byte to 
the main system via the data bus. 


After completion of the read operation from the 
current sector, the Sector Number is incremented 
by one, and the data from the next sector is read 
and output on the data bus. This continuous read 
function is called a "Multi-sector Read Operation." 
The Read Data Command may be terminated by 
the receipt of a Terminal Count signal. TC should 
be issued at the same time that the DACK for the 
last byte of data is sent. Upon receipt of this sig- 
nal, the FDC stops outputting data to the 
processor, but will continue to read data from the 
current sector, check CRC (Cyclic Redundancy 
Count) bytes, and then at the end of the sector 
terminate the Read Data command. The amount 
of data which can be handled with a single com- 
mand to the FDC depends upon MT (multitrack), 
MF (MFM/FM), and N (number of bytes/sector). 
Table 31 lists the Transfer Capacity. 


Multi- | MFM/ | Bytes |Maximum Transfer| Final Sector Read 
Track | FM /Sect | Capacity From 
MT MF or (Bytes/Sector) Diskettes 
N Number of Sectors 
0 00 =| (128)(26)=3,328 26 at Side 0 or 
1 O01 | (256)(26)=6,656 26 at Side 1 
1 0 00 =| (128)(52)=6,656 26 at Side 1 
| 1 01 (256) (52)=13,312 
0 01 = | (256)(15)=3,840 15 at Side 0 
| 02 (512)(15)=7,680 
1 0 01 (256) (30)=7,680 15 at Side 1 
{ | 02 (512)(15)=15,360 
0 02 =| (512)(8)=4,096 8 at Side 1 or 
1 03 | (1024)(8)=8,192 8 at Side 1 
1 0 02 = | (512)(16)=8,192 8 at Side 1 
{ | 03 (1024)(16)=16,384 


TABLE 16-1. TRANSFER CAPACITY 




























The "multi-track" function (MT) allows the FDC to 
read data from both sides of the diskette. For a 
particular cylinder, data will be transferred starting 


COMMAND DESCRIPTIONS 


at Sector 1, Side 0 and completing at Sector L, 
Side 1 (Sector L = last sector on the side). Note, 
this function pertains to only one cylinder (the 
same track) on each side of the diskette. 


When N = 0, then DTL defines the data length 
which the FDC must treat as a sector. If DTL is 
smaller than the actual data length in a sector, the 
data beyond DTL in the sector is not sent to the 
Data Bus. The FDC reads (internally) the com- 
plete sector performing the CRC check, and 
depending upon the manner of command termina- 
tion, may perform a Multi-Sector Read operation. 
When N is non-zero, then DTL has no meaning 
and should be set to FF hexadecimal. 


At the completion of the Read Data command, the 
head is not unloaded until after Head Unload 
Time Interval (specified in the Specify command) 
has elapsed. If the processor issues another com- 
mand before the head unloads, then the head set- 
tling time may be saved between subsequent 
reads. This time out is particularly valuable when 
a diskette is copied from one drive to another. 


If the FDC detects the Index Hole twice without 
finding the right sector, (indicated in ’R’), then the 
FDC sets the ND (No Data) flag in Status Register 
1 to a 1 (high), and terminates the Read Data 
command. (Status Register 0 also has bits 7 and 
6 set to 0 and 1 respectively.) 


After reading the ID and Data Fields in each sec- 
tor, the FDC checks the CRC bytes. If a read error 
is detected (incorrect CRC in ID field), the FDC 
sets the DE (Data Error) flag in Status Register 1 
to 1 (high). If a CRC error occurs in the Data 
Field, the FDC also sets the DD (Data Error in 
Data Field) flag in Status Register 2 to a 1 (high), 
and terminates the Read Data command. (Status 
Register 0 also has bits 7 and 6 set to O and 1 
respectively. ) 


lf the FDC reads a Deleted Data Address Mark off 
the diskette, and the SK bit (bit D5 in the first 
Command Word) is not set (SK = 0), then the 
FDC sets the CM (Control Mark) flag in Status 
Register 2 to a 1 (high), and terminates the Read 
Data command, after reading all the data in the 
sector. If SK = 1, the FDC skips the sector with 
the Deleted Data Address Mark and reads the 
next sector. The CRC bits in the deleted data field 
are not checked when SK = 1. 
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During disk data transfers between the FDC and 
the processor, via the data bus, the FDC must be 
serviced by the processor every 27 us in the FM 
mode, and every 13 us in the MFM mode, or the 
FDC sets the OR (Overrun) flag in Status Register 
1 to a 1 (high), and terminates the Read Data 
command. 


lf the processor terminates a read (or write) 
operation in the FDC, then the ID information in 
the Result phase is dependent upon the state of 
the MT bit and EOT byte. Table 16-2 shows the 
values for C, H, R, and N, when the processor 
terminates the command. 











Final Sector 
Transferred 
to Procesor 


0 [Less than EOT _| 
0 |EqualtoEOT | 
jo 
oO | 
Hes 4 
cid 





ID Information at Result 
Phase 
Cc 












H R N 


Ret |NC | 
INC | 


NC 
NC 
C 
NC 
C 
C 
NC 





Z|O|z 
Be 
an 


EqualtoEOT __|c 
1 
1 |EqualtoEOT _—‘[C+1_|LsB 


TABLE 16-2. C, H, R, AND N VALUES 
Notes 
NC (No Change) The same value as the one at the beginning of 
command execution 
LSB (Least Significant bit) The least significant bit of H is com- 
plemented 


INC _| 


ait 
z |r lz |z |2z|2 |2 
wedidididid 


R+1 
+1 


R 





gg Pay 





16.2 WRITE DATA 


A set of nine bytes is required to set the FDC into 
the Write Data mode. After the Write Data com- 
mand has been issued the FDC loads the head (if 
it is in the unloaded state), waits the specified 
head settling time (defined in the Specify com- 
mand), and begins reading ID fields. When all four 
bytes loaded during the command (C, H, R, N) 
match the four bytes of the ID field from the dis- 
kette, the FDC takes data from the processor 
byte-by-byte via the data bus and outputs it to the 
FDD. 


After writing data into the current sector, the sec- 
tor number stored in ’R’ is incremented by one, 
and the next data field is written into. The FDC 
continues this ‘Multisector Write Operation’ until 
the issuance of a Terminal Count signal. If a Ter- 
minal Count signal is sent to the FDC it continues 
writing into the current sector to complete the data 
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field. If the Terminal Count signal is received while 
a data field is being written, then the remainder of 
the data field is filled with zeros. 


The FDC reads the ID field of each sector and 
checks the CRC bytes. If the FDC detects a read 
error (CRC error) in one of the ID fields, it sets the 
DE (Data Error) flag of Status Register 1 to a 1 
(high) and terminates the Write Data command. 
(Status Register 0 also has bits 7 and 6 set to 0 
and 1 respectively.) 


The Write command operates in much the same 
manner as the Read command. The following 
items are the same, and one should refer to the 
Read Data command for details: 


¢ Transfer capacity 

¢ EN (End of Cylinder) flag 

¢ ND (No Data) flag 

¢ Head Unload Time interval 


¢ ID Information when the processor terminates 
command 


¢ Definition of DTL when N = 0 and when N #0 


In the Write Data mode, data transfers between 
the processor and FDC via the data bus, must 
occur every 27 us in the FM mode and every 13 
us in the MFM mode. If the time interval between 
data transfers is longer than this, then the FDC 
sets the OR (Overrun) flag in Status Register 1 to 
a 1 (high) and terminates the Write Data com- 
mand. (Status Register 0 also has bits 7 and 6 set 
to 0 and 1 respectively.) 


16.3. WRITE DELETED DATA 


This command is the same as the Write Data 
command except a Deleted Data Address mark is 
written at the beginning of the data field instead of 
the normal Data Address mark. 


16.4 READ DELETED DATA 


This command is the same as the Read Data 
command except that when the FDC detects a 
Data Address mark at the beginning of a data field 
(and SK = 0 [low}), it will read all the data in the 
sector and set the CM flag in Status Register 2 to 
a 1 (high), and then terminate the command. If SK 
= 1, then the FDC skips the sector with the Data 
Address mark and reads the next sector. 
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16.5 READ A TRACK 


This command is similar to the Read Data com- 
mand except that this is a continuous Read 
operation where the entire data field from each of 
the sectors is read. Immediately after sensing the 
index hole, the FDC starts reading all data fields 
on the track as continuous blocks of data. If the 
FDC finds an error in the ID or Data CRC check 
bytes, it continues to read data from the track. 
The FDC compares the ID information read from 
each sector with the value stored in the IDR and 
sets the ND flag of Status Register 1 to a 1 (high) 
if there is no comparison. Multitrack or skip opera- 
tions are not allowed with this command. 


This command terminates when the number of 
sectors read is equal to EOT. If the FDC does not 
find an ID Address mark on the diskette after it 
senses the index hold for the second time, it sets 
the MA (Missing Address mark) flag in Status 
Register 1 to a 1 (high) and terminates the com- 
mand. (Status Register 0 has bits 7 and 6 set to 0 
and 1 respectively.) 


16.6 READID 


The Read ID command is used to give the 
present position of the recording head. The FDC 
stores the values from the first ID field it is able to 
read. If no proper ID Address mark is found on the 
diskette before the index hole is encountered for 
the second time, then the MA (Missing Address 
mark) flag in Status Register 1 is set to a 1 (high), 
and if no data is found then the ND (No Data) flag 
is also set in Status Register 1 to a 1 (high). The 
command is then terminated with bits 7 and 6 in 
Status Register 0 set to 0 and 1 respectively. 
During this command there is no data transfer 
between FDC and the CPU except during the 
result phase. 
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16.7 FORMAT A TRACK 


The Format command allows an entire track to be 
formatted. After the index hole is detected, data is 
written on the diskette; Gaps, Address marks, ID 
fields and data fields, all per the IBM System 34 
(double density) or System 3740 (single density) 
format are recorded. The particular format which 
will be written is controlled by the values 
programmed into N (number of bytes/sector), SC 
(sectors/cylinder), GPL (gap length), and D (data 
pattern) which are supplied by the processor 
during the Command phase. The data field is 
filled with the byte of data stored in D. The ID field 
for each sector is supplied by the processor; that 
is, four data requests per sector are made by the 
FDC for C (cylinder number), H (head number), R 
(sector number) and N (number of bytes/sector). 
This allows the diskette to be formatted with non- 
sequential sector numbers, if desired. 


The processor must send new values for C, H, R, 
and N to the WD37C65C for each sector on the 
track. If FDC is set for the DMA mode, it will issue 
four DMA requests per sector. If it is set for the 
Interrupt mode, it will issue four interrupts per sec- 
tor and the processor must supply C, H, R, and N 
loads for each sector. The contents of the R 
register are incremented by 1 after each sector is 
formatted; thus, the R register contains a value of 
R when it is read during the Result phase. This 
incrementing and formaning continues for the 
whole track until the FDC detects the index hole 
for the second time, whereupon it terminates the 
command. 
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Table 16-3 shows the relationship between N, SC, 
and GPL for various sector sizes. 


Sector Size SC |GPL /GPL 
Bytes/sector 1 2,3 
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3 1/2" Sony Microflopp 








TABLE 16-3. N, SC AND GPL RELATIONSHIP 
Notes: 
1. Suggested values of GPL in Read 0, Write commands to 
avoid splice point between data field and ID field of contiguous 
sections 
2. Suggested values of GPL in format command 
3. All values except sector size are hexadecimal. 
4 In MFM mode FDC cannot perform a Read/Write/format 
operation with 126 bytes/sector (N=00) 
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16.8 SCAN COMMANDS 


The Scan commands allow data which is being 
read from the diskette to be compared against 
data which is being supplied from the main sys- 
tem. The FDC compares the data on a byte-by- 
byte basis and looks for a sector of data which 
meets the conditions of DFpp = DProcessor, Depps< 
DProcessor, Of DEDD = DProcessor. The hexadecimal 
byte of FF either from memory or from FDD can 
be used as a mask byte because it always meets 
the condition of the comparison. Ones comple- 
ment arithmetic is used for comparison (FF = 
largest number, 00 = smallest number). After a 
whole sector of data is compared, if the conditions 
are not met, the sector number is incremented (R 
+ STP -g R), and the scan operation is continued. 
The scan operation continues until one of the fol- 
lowing conditions occur: the conditions for scan 
are met (equal, low, or high), the last sector on the 
track is reached (EOT), or the terminal count sig- 
nal is received. 


If the conditions for scan are met, then the FDC 
sets the SH (Scan Hit) flag of Status Register 2 to 
a 1 (high) and terminates the Scan command. If 
the conditions for scan are not met between the 
starting sector (as specified by R) and the last 
sector on the cylinder (EOT), then the FDC sets 
the SN (Scan Not Satisfied) flag of Status 
Register 2 to a 1 (high) and terminates the Scan 
command. The receipt of a Terminal Count signal 
from the processor or DMA controller durring the 
scan operation will cause the FDC to complete 
the comparison of the particular byte which is in 
process and then to terminate the command. 
Table 16-4 shows the status of bits SH and SN 
under various conditions of Scan. 
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Bit 2=SN Bit 3=SH 
ScanEqual jo |i. | 
ScanEqal |1 lo __ 


Scan Low or 
Equal 










Comments 









Drrp=D Processor 






DFrp#D Processor 


Drrp=D Processor 











Drro<D Processor 


Drrp>D Processor 


Drrp=D Processor 


Equal 
aor. 
Equal 
aor. 
Equal 

Equal . 

Scan High or/1 

Equal 


TABLE 16-4. STATUS OF BITS SH AND SN 







Drrp>D Processor 





Drrp<D Processor 





If the FDC encounters a Deleted Data Address 
mark on one of the sectors (and SK = 0), then it 
regards the sector as the last sector on the 
cylinder, sets the CM (Control mark) flag of Status 
Register 2 to a 1 (high) and terminates the com- 


mand. If SK = 1, the FDC skips the’sector with the. 


Deleted Address mark and reads the next sector. 
In the second case (SK = 1), the FDC sets the 
CM (Control mark) flag of Status Register 2 to a 1 
(high) in order to show that a deleted sector had 
been encountered. 


When either the STP (contiguous sectors = 01, or 
alternate sectors = 02) sectors are read or the MT 
(Multitrack) is programmed, it is necessary to 
remember that the last sector on the track must 
be read. For example, if STP = 02, MT = 0, the 
sectors are numbered sequentially 1 through 26 
and the Scan command is started at sector 21, 
the following will happen: sectors 21, 23, and 25 
will be read, then the next sector (26) will be 
skipped and the index hole will be encountered 
before the EOT value of 26 can be read. This will 
result in an abnormal termination of the com- 
mand. If the EOT had been set at 25 or the scan- 
ning started at sector 20, then the Scan command 
would be completed in a normal manner. 


During the Scan command, data is supplied by 
either the processor or DMA controller for com- 
parison against the data read from the diskette. In 
order to avoid having the OR (Overrun) flag set in 
Status Register 1, it is necessary to have the data 
available in less than 27 us (FM mode) or 13 us 
(MFM mode). If an Overrun occurs, the FDC ends 
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the command with bits 7 and 6 of Status Register 
0 set to 0 and 1, respectively. 


16.9 SEEK 


The Read/Write head within the FDD is moved 
from cylinder to cylinder under control of the Seek 
command. FDC has four independent Present 
Cylinder Registers for each drive. They are 
cleared only after the Recalibrate command. The 
FDC compares the PCN (Present Cylinder Num- 
ber) which is the current head position with the 
NCN (New Cylinder Number), and if there is a 
difference, performs the following operations: 
PCN < NCN: Direction signal to FDD set to a 1 
(high), and step pulses are issued. 
(Step In) 
PCN > NCN: Direction signal to FDD set to a 0 
(low), and step pulses are issued. 
(Step Out) 
The rate at which step pulses are issued is con- 
trolled by SRT (Stepping Rate Time) in the 
Specify command. After each step pulse is issued 
NCN is compared against PCN, and when NCN = 
PCN, the SE (Seek End) flag is set in Status 
Register 0 to a 1 (high), and the command is 
terminated. At this point FDC interrupt goes high. 
Bits DoB-D3B in the Main Status Register are set 
during the Seek operation and are cleared by the 
Sense Interrupt Status command. 


During the command phase of the Seek operation 
the FDC is in the FDC Busy state; but during the 
Execution phase, it is in the non-busy state. While 
the FDC is in the non-busy state, another Seek 
command may be issued, and in this manner 
parallel Seek operations may be done on up to 
four drives at once. No other command can be 
issued as long as the FDC is in the process of 
sending step pulses to any drive. 


If the time to write three bytes of Seek command 
exceeds 150 us, the timing between the first two 
step pulses may be shorter than that set in the 
Specify command by as much as 1ms. 


16.10 RECALIBRATE 


The function of this command is to retract the 
Read/Write head within the FDD to the Track 0 
position. The FDC clears the contents of the PCN 
counter and checks the status of the Track 0 sig- 
nal from the FDD. As long as the Track 0 signal is 
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low, the Direction signal remains O (low) and step 
pulses are issued. When the Track 0 signal goes 
high, the SE (Seek End) flag in Status Register 0 
is set to a 1 (high) and the command is ter- 
minated. If the Track O signal is still low after 255 
step pulses have been issued, (for the WD37C65 
and the WD37C65A) or 77 step pulses 
(WD37C65B/C), the FDC sets the SE (Seek End) 
and EC (Equipment Check) flags of Status 
Register 0 to both 1s (highs), and terminates the 
command after bits 7 and 6 of Status Register 0 
are set to 0 and 1 respectively. 


The ability to do overlap Recalibrate commands to 
multiple FDDs and the loss of the Ready signal, 
as described in the Seek command, also applies 
to the Recalibrate command. 


16.11 SENSE INTERRUPT STATUS 


An Interrupt signal is generated by the FDC for 
one of the following reasons: 


1. Upon entering the Result phase of: 
a. Read Data command 


b. Read A Track command 

c. Read ID command 

d. Read Deleted Data command 
e. Write Data command 

f. Format A Cylinder command 
g. Write Deleted Data command 
h. Scan commands 


2. Ready Line of FDD changes state 
3. End of Seek or Recalibrate command 
4. During Execution phase in the non-DMA mode 


Interrupts caused by reasons 1 and 4 above 
occur during normal command operations and are 
easily discernible by the processor. During an Ex- 
ecution phase in non-DMA mode, DB5 in the Main 
Status Register is high. Upon entering the Result 
phase, this bit gets cleared. Reasons 1 and 4 do 
not require Sense Interrupt Status commands. 
The interrupt is cleared by Reading/Writing data 
to the FDC. Interrupts caused by reasons 2 and 3 
above may be uniquely identified with the aid of 
the Sense Interrupt Status command. This com- 
mand, when issued, resets the Interrupt signal 
and via bits 5, 6, and 7 of Status Register 0 iden- 
tifies the cause of the interrupt. 


WD37C65C 


Interrupt Code 
Bit 6 


Bit 7 |Cause 


Ready Line changed state, either 


Normal Termination of Seek or 
Recalibrate command 
Abnormal Termination of Seek or 
Recalibrate command 


TABLE 16-5. INTERRUPT CAUSE 





The Sense Interrupt Status command is used in 
conjunction with the Seek and Recalibrate com- 
mands which have no Result phase. When the 
disk drive has reached the desired head position, 
the WD37C65C will set the Interrupt line true. The 
host CPU must then issue a Sense Interrupt 
Status command to determine the actual cause of 
the interrupt, which could be Seek End or a 
change in ready status from one of the drives. 
See Figure 16-1. 


The Specify command sets the initial values for 
each of the three internal timers. The HUT (Head 
Unload Time) defines the time from the end of the 
Execution phase of one of the Read/Write com- 
mands to the head unload state. This timer is 
programmable from 16 to 240 ms in increments of 
16 ms (01 = 16 ms, 02 =82 ms... . OF16 = 240 
ms). The SRT (Step Rate Time) defines the time 
interval between adjacent step pulses. This timer 
is programmable from 1 to 16 ms in increments of 
1 ms (F=1ms,E=2ms,D=3 ms, etc.). The 
HLT (Head Load Time) defines the time between 
when the Head Load signal goes high and the 
Read/Write operation starts. This timer is 
programmable from 2 to 254 ms in increments of 
2ms (01 =2 ms, 02=4ms,03=6ms.../7F= 
254 ms). 


The time intervals mentioned above are a direct 
function of the clock (CLK on pin 23). Times indi- 
cated above are for a 16 MHz clock; if the clock 
was reduced to 8 MHz, then all time intervals are 
increased by a factor of 2. If the clock was in- 
creased to 32 MHz, then all time intervals are 
decreased by half. 


The choice of DMA or non-DMA operation is 
made by the ND (Non-DMA) bit. When this bit is 
high (ND = 1), the Non-DMA mode is selected; 
and when ND = 0, the DMA mode is selected. 





fp 11/18/91 


26-41 





WD37C65C 


INT 
cs Lira al 


J LUM 


HD/Drive Not Written 
into WD37C65C 


Cc 
og 
a <@) 
sO 
Bi 
(2) 
coQ 
= 
= 
= 
8 

Cc 
Oo 
= 
os 


NCN Written into WD37C65C 





COMMAND DESCRIPTIONS 


Seek or (Recalibrate) Command ense Interrupt Status Command 
Command Phase Execution Phase Command iden Phase 
| 


OP Code for Instruction 
Written into WD37C65C 
Status Register STO 
Read by Processor 
RCN Read by 

Processor 


FIGURE 16-1. SEEK, RECALIBRATE, AND SENSE INTERRUPT 


16.12 SENSE DRIVE STATUS 


This command may be used by the processor to 
obtain the status of the FDDs. Status Register 3 
contains the Drive Status information stored inter- 
nally in FDC registers. 


16.13 INVALID 


If an Invalid command is sent to the FDC (a com- 
mand not defined above), then the FDC will ter- 
minate the command after bits 7 and 6 of Status 
Register 0 are set to 1 and O respectively. No 
interrupt is generated during this condition. Bits 6 


and 7 (DIO and RQM) in the Main Status Register 
are both high (1), indicating to the processor that 
the WD37C65C is in the Result phase and the 
contents of Status Register 0 (STO) must be read. 
When the processor reads Status Register 0, it 
will find an 80 hex, indicating an Invalid command 
was received. 

A Sense Interrupt Status command must be sent 
after a Seek or Recalibrate interrupt; otherwise 
the FDC will consider the next command to be an 
invalid command. In some applications, the user 
may wish to use this command as a No-Op com- 
mand to place the FDC in a standby or No Opera- 
tion state. 
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AP4a | SYNC | IAM | GAP 11|SYNC | IDAM | C S C |GAP2| SYNC | DATAAM DATA C | GAP 3 GAP4b 
40x 6x 26x 6x Y|H;/E}]NiR 11x 1 R | 
FF 00 FC FF 00 FE bw D-BG- Oue€ FF FB orF8 C 


Index 








Repeat N Times | 


FIGURE 16-2. WD37C65C FM MODE FORMAT 


AP4a Se ee ee SYNC C S C1/GAP2|1SYNC| DATAAM | DATA | C|GAP3 (GAP4b 
gox | 12x | 3x 50x | 12x YIHIE R| 22x | 12x x _FB ‘ Ri 4 
FF | 00 FF | 00 L|D|C C|_E 00 F8 C 





Index 





Repeat N Times ~—— 


FIGURE 16-3. WD37C65C MFM MODE FORMAT 


WD37C65/A/B WD37C65/C 


2 XTAL oscillators. 2 XTAL oscillators. 
- 16 MHz for standard data rate - 32 MHz for standard data rate 
(up to 500 kb/s MFM). (up to 1 Mb/s MFM) or 16 MHz for 
standard data rate (up to 500 kb/s MFM). 
- 9.6 MHz for non-standard rate. 
300 kb/s AT/EISA 






























- 9.6 MHz for non-standard rate. 
300 kb/s PCAT 


Supports data rate up to 500 Kb/s. Supports data rate up to 1 Mb/s 


1. 
~ e not Support power down mode. Supports power down mode feature, 
standby ICC = 100 uA max. 
4. PCVAL pin for selecting the precomp|PCVAL pin for selecting the precomp values 
values. and a feature to disable write precomp. 


TABLE 16-6. DIFFERENCES BETWEEN WD37C65/A/B AND WD37C65C 
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17.0 DC ELECTRICAL SPECIFICATIONS 


17.1 MAXIMUM RATINGS 


Operating Temperature |0°C (32°F) to 70°C 
158°F 
F) to 
Vi 












Storage Temperature |-55°C (-67° 
+125°C (257°F 
oltage on any pin with |-0.3V to VCC +0.3V 
respect to ground 
respect to ground 


NOTE 





Maximum limits indicate where permanent device 
damage occurs. Continuous operation at these 
limits is not intended and should be limited to 
those conditions specified in the DC Operating 
Characteristics. 


DC ELECTRICAL SPECIFICATIONS 


17.2 STANDARD TEST CONDITIONS 


The characteristics below apply for the following 
standard test conditions, unless otherwise noted. 
All voltages are referenced to ground. 


Operating temperature|O°C (32°F) to 70°C 
range (TA 158F 

Power supply voltage|+5V + 10% 

VCC 
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17.3. DC OPERATING CHARACTERISTICS 




























PARAMETER MIN [MAX {UNITS | 
VIL Input Low Voltage-DataBus&xTOSc.|-- jos iv 
Input High Volt - Data Bus & XTOSC Boy ee 
VILT —|InputLow Threshold- Schmitt Trigger fot iV 
Output Low- DBx,IRQ,DMA,:lo=24.0mA |--- ——s-(|0.4 V 

VOH Output High-DBx,IRa,DMA,;lo=-5.0mA [28 --- [V 
VOLHC ———_—*|OutputLow-High Current;lo=48.0mA ss |-- 04 iV 
ILUL Latch UpCurrentlow sf. mA 







Latch Up Current High 

C 
PD [Power Dissipation: ICC Max 
Power Qualified Reset Threshold 





'@) 










Note 1. Vin = VCC or GND, lo = O mA. Note 3. Includes open drain high current drivers at 


Vol = 0.4V. 
Note 2. Includes DBx, IRQ and DMA; lo = -5.0 mA 
source loads. 
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18.0 AC TIMING CHARACTERISTICS 
The following notes apply to all parameters 4.CY =CLK1 or XT1 period 

















presented in this section: 5. MCY = MCLK period, dependent on selected 
data rate 
1. TA = 0°C (32°F) to 70°C (158°F) 6. WCY = WCLK period, dependent on selected 
2. VCC = +5V + 10% data rate 
3. CL= 100 pf 
SYMBOL |PARAMETER (MIN 
{CY 
13.5 nS 
tR [Clock Rise Time (Vin0.8to2.0) fs ns 
tF [Clock Fall Time (Vin2.0to0.8) f= ns 
tAR__—|AO,CS,DACK Set Up TimetoRDLow [0 
tRA____—(|AO,CS,DACK Hold TimetoRD High 0 
tRR RDWidth 
tRD _—'|DataAccessTimeFromRDLow [= 
ow 
tWA AO,CS,DACK,LDCR,LDOR, Hold Time From WR 
High 
iww_[WRWidth 
+150nS 


1MCY 
+150nS 






WI IRQ Reset Delay Time From WR High 


tao ol 











MCY 02 


li 


AM 
MA 
AA 
TC 
RST 

Reset Width - Software Reset 


SRST Reset Width - Software Reset 


RDD RDD Active Time Low 


= 


DMA Cycle Time 
MAR 


WM 


Oo DD |DID 1G 
< < 


ep) 











NO jf iH | ho 

io) hm |C 
i O1 
© 


>< ulc 


tWDD WD Write Data Width Low /2 (TYP WCY 
tDST DIRC Hold & Set Up To STEP Low MCY 
MCY 
24 MCY 
132 MCY 
STD IDIRC HoldTimeAfterSTEP GC MCY 
MCY 
RDDelayFromDMA 
MW WRDelayFromDMA i (iss—~—“*‘séis*ONSC“‘;R:COd” 
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SYMBOL |PARAMETER— ———“‘;SCSSC*dMINN =~ (MAX [UNITS 
tMRW [RD OrWRResponse FromDMAHigh [= 48 |MCY 
1CA _—|Chip Access Delay FromRSTLow-TTL —s—s*([32_——s [=> |MCY 
1CAS _|Chip Access Delay FromtSRSTLow  ————s([40— > MC 
500 ps 
1000 ps 
1TCR__—'[TC Delay FromLastDMAOrIRQ,RD—sd(O—C si MCY 
tTCW _—(|TC Delay FromDMAOrIRQ,WR_ S(O «* 818 
Teycle _|ClockCycle — ——“—*‘“C;*~*dONSC“‘SCSL! SSIS 
Tp-high _|ClockHigh ——“‘“‘Z'S 
Tplow _|ClockLow ——“‘“‘;‘~* SS 

Vin .8 to 2.0 
rt femme Rete 

Vin 2.0 to .8 





Ya 11/18/91 26-47 





WD37C65C AC TIMING CHARACTERISTICS 


DD 
= oe = 


__ tRD us 


—_ 
ae, 





FIGURE 18-1. READ TIMING 


DATA X Data Valid | —X Valid | 


IRQ 





FIGURE 18-2. WRITE TIMING 
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DMA 


DACK 


RD or WR | 


tMR —, A 
tMW 
— tRD = wo | 
DATA data vaio] Valid 


| i 
tDW 





FIGURE 18-3. DMA TIMING 


DMA or IRQ / 


tTCR 
tTCW 





FIGURE 18-4. TERMINAL COUNT TIMING 
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FIGURE 18-5. RESET TIMING 





FIGURE 18-6. DISK DRIVE TIMING 
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16 MHz CLOCK 


ae tCY 





FIGURE 18-7. CLOCK TIMING 
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